#### UNIVERSIDAD DE GRANADA.

# ESCUELA TECNICA SUPERIOR DE INGENIERIAS INFORMATICA Y DE TELECOMUNICACIÓN.



Departamento de Arquitectura y Tecnología de Computadores.

TECNOLOGÍA Y ORGANIZACIÓN DE COMPUTADORES.

PRÁCTICA 3. ANÁLISIS Y REALIZACIÓN DE UNA UNIDAD ARITMÉTICO-LÓGICA (ALU) DE 4 BITS.

1º GRADO EN INGENIERÍA INFORMÁTICA.

# PRÁCTICA 3.

# ANÁLISIS Y REALIZACIÓN DE UNA UNIDAD ARITMÉTICO-LÓGICA (ALU) DE 4 BITS.

#### Objetivos:

 Analizar teóricamente una Unidad Aritmético-Lógica de 4 bits a partir de los esquemáticos de los circuitos que la implementa. Montar y verificar su funcionamiento en un simulador lógico.

# Material necesario para el desarrollo de la práctica:

- Guión de prácticas disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>03.-PRACTICAS>PRACTICA\_3 >PRACTICA 3 TOC.PDF.
- Material del Tema 3º disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>01.-TEORIA y PROBLEMAS>TEMA\_3> 03.-TEMA\_3\_TOC\_SISTEMAS\_COMBINACIONALES.PDF. Apartado 3.4.2. ALU y 3.4.4.- Multiplexores/Demultiplexores.
- Videoclase del Tema 3. Clase 1 (minutos 34 a 38) ubicada en:
  <a href="https://drive.google.com/open?id=1LYnJsHz10UzPIDzAcr6vlaYK1XLKCTeb">https://drive.google.com/open?id=1LYnJsHz10UzPIDzAcr6vlaYK1XLKCTeb</a>
- Videoclase del Tema 3. Clase 2 (minutos 9 a 16) ubicada en:
  <a href="https://drive.google.com/open?id=1WJY2ZxF5grFL4WfDU2vcmlVtuPiZXT70">https://drive.google.com/open?id=1WJY2ZxF5grFL4WfDU2vcmlVtuPiZXT70</a>
- Videoclase de la Práctica 3 ubicada en: https://drive.google.com/file/d/1CMJgHFSShuVvLPrGHgwUhVyp4clk4qU4/view ?usp=sharing
- Seminario 5. Guía de Trabajo Autónomo. PARTE 1: INTRODUCCIÓN AL MANEJO DE UN SIMULADOR LÓGICO, páginas 1-3 a 1-10 (ambas inclusive) disponible en SWAD en el apartado ARCHIVOS>DOCUMENTOS>02.-SEMINARIOS>SEMINARIO\_5>05.-SEMINARIO\_5\_TOC\_SIMULADOR\_ENTRENADOR\_LOGICO\_GUIA.
- Videoclases de Simulador Lógico disponibles en: https://drive.google.com/open?id=10sHlQ51fdcfGDe0p 6b7LtTTbwpovXop https://drive.google.com/open?id=1gvQlrsORnpHDrqPwKSyvEi2vprk6pulhttps://drive.google.com/open?id=16hp2vr4GTzM4j0 wm1KFXlB0FjWfnmFn https://drive.google.com/open?id=1tlFeDH0nthSq09fc75XL1NSP22aDifh5
- Software Simulador Lógico LogicWorks.

#### 3.1. Estudio preliminar:

Se pretende analizar, realizar y verificar, utilizando un simulador lógico, una Unidad Aritmético-Lógica (ALU) que sea capaz de operar con 2 datos A y B de 4 bits. Esta ALU proporcionará las operaciones aritméticas y lógicas indicadas en la *Figura 3.1*. Cada operación se seleccionará según el valor que tomen  $(1 \ 6 \ 0)$  unas señales de control  $S_2$ ,  $S_1$ ,  $S_0$  y un acarreo de entrada  $C_{in}$ .



Figura 3.1: Operaciones que realiza la ALU. Esquema general de entradas y salidas.

La estructura jerárquica modular mediante Logic Works de la ALU se establece en las *Figuras 3.2, 3.3 y 3.4*. Se parte de los circuitos de la *Figura 3.2(a) y 3.2(b)* que corresponden a las etapas aritmética y lógica, respectivamente. Ambas operan sobre datos de un bit. La etapa aritmética incluye a un sumador completo de un bit (S-1bit) y la etapa lógica un multiplexor 4:1. Estos módulos se "encapsulan" dando lugar a los bloques indicados en la parte inferior de las *Figura 3.2(a) y (b)*.





Figura 3.2. Estructura modular de cada elemento aritmético ó lógico de 1 bit.

En la *Figura 3.3* se ilustra el diseño y "encapsulado" de la Etapa ALU de un bit que integra los módulos anteriores de la *Figura 3.2*.



Figura 3.3. Estructura de la Etapa ALU de un bit.

En la *Figura 3.4* se ilustra el diseño y "encapsulado" de una ALU de 4 bits, utilizando 4 Etapas ALU de un bit, como las diseñadas en la *Figura 3.3*.



Figura 3.3 (bis). Estructura de un MUX 2 a 1 (izquierda) y de un MUX 4 a 1 (derecha).



Figura 3.4. Estructura completa de la ALU para palabras de 4 bits.

# 3.2. Realización práctica:

- 1. Trabajo para realizar ANTES de la sesión de prácticas (debe venir preparado):
- 1.1. Analice teóricamente los esquemáticos de los circuitos y etapas de la ALU mostradas en las *Figuras 3.2, 3.3* y *3.4*. Deduzca, razonadamente, para qué combinaciones de las señales de control S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> y valor de C<sub>in</sub> se realiza cada una de las operaciones indicadas en la *Figura 3.1*. El resultado indíquelo en la columna de la *Tabla 3.1* correspondiente a "Operaciones de la ALU deducidas Teóricamente".
- 1.2. A la vista del apartado anterior, con las "Operaciones ALU deducidas Teóricamente" y tomando como datos A y B de entrada de 4 bits los siguientes A = 1101 y B = 0111, obtenga, para cada una de las operaciones obtenidas en el apartado anterior, el resultado (dato G) que debería obtenerse.

| SEÑALES<br>S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> C <sub>in</sub> | Operaciones de la ALU,<br>deducidas Teóricamente | Operaciones de la ALU deducidas Experimentalmente |
|-------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------|
| 0000                                                                    |                                                  |                                                   |
| 0001                                                                    |                                                  |                                                   |
| 0010                                                                    |                                                  |                                                   |
| 0 0 1 1                                                                 |                                                  |                                                   |
| 0100                                                                    |                                                  |                                                   |
| 0101                                                                    |                                                  |                                                   |
| 0110                                                                    |                                                  |                                                   |
| 0111                                                                    |                                                  |                                                   |
| 1000                                                                    |                                                  |                                                   |
| 1001                                                                    |                                                  |                                                   |
| 1010                                                                    |                                                  |                                                   |
| 1011                                                                    |                                                  |                                                   |
| 1100                                                                    |                                                  |                                                   |
| 1101                                                                    |                                                  |                                                   |
| 1110                                                                    |                                                  |                                                   |
| 1111                                                                    |                                                  |                                                   |

Tabla 3.1

- 2. Realice en LogicWorks la ALU de la *Figura 3.4* y **el circuito de prueba de la** *Figura 3.5*. Para ello, use (de la biblioteca *Simulation IO.clf* ) dos componentes HEX KEYBOARD wo/STB para generar los datos A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub> y B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub>, un componente HEX\_DISPLAY para visualizar las salidas G<sub>3</sub>G<sub>2</sub>G<sub>1</sub>G<sub>0</sub>, cuatro BINARY SWITCH para generar las señales S<sub>2</sub>S<sub>1</sub>S<sub>0</sub>C<sub>in</sub>, y un BINARY PROBE para visualizar la salida C<sub>out</sub> y así realizar la prueba experimental del circuito.
- 3. En el Laboratorio, introduzca los ejemplos, deducidos teóricamente en el apartado (1.2), en el circuito de prueba y **deduzca experimentalmente** los valores de las señales de control S<sub>2</sub>,S<sub>1</sub>,S<sub>0</sub> y valor de C<sub>in</sub> correspondiente a cada una de las operaciones indicadas en la *Figura 3.1* y **rellene la última columna** de la *Tabla 3.1*. Compruebe que los resultados obtenidos experimentalmente coinciden con los obtenidos en el apartado 1.2.



Figura 3.5. Circuito de prueba de la ALU de 4 bits.